<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body{
            height: 2000px;
        }
    </style>
</head>

<body>

    <script>
        // 防抖 在一定时间段内 只触发一次
        // 触发时候不能使用定时器特别是setInterval

        function debounce(fn) {
            let timer= null
            // console.log( fn,delay,'触发');
            // console.log(arguments,'参数')
            return function (a = 1) {
                const args = arguments
                console.log(args, '参数')
                if (timer) {
                    // console.log(timer,'定时器');
                    // console.log(2);
                    clearTimeout(timer)
                    // console.log(timer,'清除后');
                }
                timer = setTimeout(() => {
                    console.log(3);
                    fn.apply(this,args)
                }, 1000)
                //  timer = setTimeout(fn, 1000)
            }
        }

        function test() {
            console.log(123, '被调用');
        }
        // 不能使用setInterval触发事件
        // setInterval(() => {
        //     // 执行方法
        //     debounce(test)
        // }, 2000)

        // function debounce(fn, delay) {
        //     let timer = null //借助闭包
        //     return function () {
        //         if (timer) {
        //             clearTimeout(timer)
        //         }
        //         timer = setTimeout(fn, delay)
        //     }
        // }

        function showTop() {
            var scrollTop = document.body.scrollTop || document.documentElement.scrollTop;
            console.log('滚动条位置：' + scrollTop);
        }
        window.onscroll = debounce(test, 1000)

    </script>
</body>

</html>